package com.ruoyi.wms.mapper;

import java.util.List;
import org.apache.ibatis.annotations.Param;
import com.ruoyi.wms.domain.WmsLocation;

/**
 * 库位信息Mapper接口
 * 
 * @author ruoyi
 * @date 2024-01-01
 */
public interface WmsLocationMapper 
{
    /**
     * 查询库位信息
     * 
     * @param id 库位信息主键
     * @return 库位信息
     */
    public WmsLocation selectWmsLocationById(Long id);

    /**
     * 查询库位信息列表
     * 
     * @param wmsLocation 库位信息
     * @return 库位信息集合
     */
    public List<WmsLocation> selectWmsLocationList(WmsLocation wmsLocation);

    /**
     * 新增库位信息
     * 
     * @param wmsLocation 库位信息
     * @return 结果
     */
    public int insertWmsLocation(WmsLocation wmsLocation);

    /**
     * 修改库位信息
     * 
     * @param wmsLocation 库位信息
     * @return 结果
     */
    public int updateWmsLocation(WmsLocation wmsLocation);

    /**
     * 删除库位信息
     * 
     * @param id 库位信息主键
     * @return 结果
     */
    public int deleteWmsLocationById(Long id);

    /**
     * 批量删除库位信息
     * 
     * @param ids 需要删除的数据主键集合
     * @return 结果
     */
    public int deleteWmsLocationByIds(Long[] ids);

    /**
     * 根据库位编码查询库位信息
     * 
     * @param locationCode 库位编码
     * @param tenantId 租户ID
     * @return 库位信息
     */
    public WmsLocation selectWmsLocationByCode(@Param("locationCode") String locationCode, @Param("tenantId") Long tenantId);

    /**
     * 根据库区ID查询库位列表
     * 
     * @param areaId 库区ID
     * @param tenantId 租户ID
     * @return 库位信息集合
     */
    public List<WmsLocation> selectWmsLocationByAreaId(@Param("areaId") Long areaId, @Param("tenantId") Long tenantId);

    /**
     * 根据仓库ID查询库位列表
     * 
     * @param warehouseId 仓库ID
     * @param tenantId 租户ID
     * @return 库位信息集合
     */
    public List<WmsLocation> selectWmsLocationByWarehouseId(@Param("warehouseId") Long warehouseId, @Param("tenantId") Long tenantId);

    /**
     * 根据仓库ID和库位类型查询库位列表
     * 
     * @param warehouseId 仓库ID
     * @param locationType 库位类型
     * @param tenantId 租户ID
     * @return 库位信息集合
     */
    public List<WmsLocation> selectWmsLocationByWarehouseIdAndType(@Param("warehouseId") Long warehouseId, @Param("locationType") Integer locationType, @Param("tenantId") Long tenantId);
}